<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>Debian 8.X搭建Lnmp&#43; Ghost 1.x 教程 - Feng&#39;s Blog - 大灰鼠的博客</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="Feng" /><meta name="description" content="其实类似的教程挺多的，尤其是Ghost 1.X版本之前的，真的不要太多，写这个教程也只是自己参照官网教程和烧饼博客之后，对自己的搭建经历作一个" /><meta name="keywords" content="feng, 折腾人生, 电脑维修, 手机玩转, 技术心得, 拆机, 网站建设, 快乐悠悠, uu, 悠悠, 博客" />






<meta name="generator" content="Hugo 0.76.5 with theme even" />


<link rel="canonical" href="https://uu126.gitee.io/2017/373.html" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png">
<link rel="manifest" href="/manifest.json">
<link rel="mask-icon" href="/safari-pinned-tab.svg" color="#5bbad5">



<link href="/sass/main.min.c7bc1becf36bcf6a9ebd25d2947e43a2eb745ddb0c9a32b43126fd7fa460c351.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="Debian 8.X搭建Lnmp&#43; Ghost 1.x 教程" />
<meta property="og:description" content="其实类似的教程挺多的，尤其是Ghost 1.X版本之前的，真的不要太多，写这个教程也只是自己参照官网教程和烧饼博客之后，对自己的搭建经历作一个" />
<meta property="og:type" content="article" />
<meta property="og:url" content="https://uu126.gitee.io/2017/373.html" />
<meta property="article:published_time" content="2017-09-28T15:22:00+00:00" />
<meta property="article:modified_time" content="2017-09-28T15:22:00+00:00" />
<meta itemprop="name" content="Debian 8.X搭建Lnmp&#43; Ghost 1.x 教程">
<meta itemprop="description" content="其实类似的教程挺多的，尤其是Ghost 1.X版本之前的，真的不要太多，写这个教程也只是自己参照官网教程和烧饼博客之后，对自己的搭建经历作一个">
<meta itemprop="datePublished" content="2017-09-28T15:22:00+00:00" />
<meta itemprop="dateModified" content="2017-09-28T15:22:00+00:00" />
<meta itemprop="wordCount" content="1725">



<meta itemprop="keywords" content="Ghost," />
<meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="Debian 8.X搭建Lnmp&#43; Ghost 1.x 教程"/>
<meta name="twitter:description" content="其实类似的教程挺多的，尤其是Ghost 1.X版本之前的，真的不要太多，写这个教程也只是自己参照官网教程和烧饼博客之后，对自己的搭建经历作一个"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/" class="logo">Feng&#39;s Blog</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/">
        <li class="mobile-menu-item">Home</li>
      </a><a href="/post/">
        <li class="mobile-menu-item">Archives</li>
      </a><a href="/tags/">
        <li class="mobile-menu-item">Tags</li>
      </a><a href="/links/">
        <li class="mobile-menu-item">Links</li>
      </a><a href="/ly/">
        <li class="mobile-menu-item">Ly</li>
      </a><a href="/about/">
        <li class="mobile-menu-item">About</li>
      </a>
  </ul>
</nav>
  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/" class="logo">Feng&#39;s Blog</a>
</div>

<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/">Home</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/post/">Archives</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/tags/">Tags</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/links/">Links</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/ly/">Ly</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/about/">About</a>
      </li>
  </ul>
</nav>
    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <article class="post">
    
    <header class="post-header">
      <h1 class="post-title">Debian 8.X搭建Lnmp&#43; Ghost 1.x 教程</h1>

      <div class="post-meta">
        <span class="post-time"> 2017-09-28 </span>
        <div class="post-category">
            <a href="/categories/%E7%BD%91%E7%AB%99%E5%BB%BA%E8%AE%BE/"> 网站建设 </a>
            </div>
          <span class="more-meta"> 约 1725 字 </span>
          <span class="more-meta"> 预计阅读 4 分钟 </span>
        
      </div>
    </header>

    <div class="post-toc" id="post-toc">
  <h2 class="post-toc-title">文章目录</h2>
  <div class="post-toc-content always-active">
    <nav id="TableOfContents">
  <ul>
    <li><a href="#apt-get--y-install-wget-screen-curl-python-for-debianubuntu">apt-get -y install wget screen curl python #for Debian/Ubuntu</a>
      <ul>
        <li>
          <ul>
            <li></li>
          </ul>
        </li>
      </ul>
    </li>
  </ul>
</nav>
  </div>
</div>
    <div class="post-content">
      <p>其实类似的教程挺多的，尤其是Ghost 1.X版本之前的，真的不要太多，写这个教程也只是自己参照官网教程和烧饼博客之后，对自己的搭建经历作一个小小的回顾。因为本人还要折腾点别的小玩意，所以不仅要将Ghost博客搭建起来，还要将PHP环境等也一同搭建，便于日后的各种折腾。好了，废话不多说，开始啰嗦之旅吧。</p>
<ul>
<li>
<p>首先搭建Lnmp，可用的环境包有很多，比如军哥的Lnmp，还有最近比较火的OneinStack等等，个人比较喜欢OneinStack，觉得功能上比前者要丰富。具体的搭建步骤，请参考<a href="https://oneinstack.com/install/" target="_blank"  rel="nofollow" >官网</a>，一路配置下来估计也要半个小时左右，成功率100%（反正我折腾了这么多次，从来没有失败过），搭建好之后，建议先做个快照！<br>
2017-8-19补充：还是把Oneinstack的搭建步骤照抄一下吧，给看的亲们省点时间233</p>
<p>yum -y install wget screen curl python #for CentOS/Redhat</p>
<h1 id="apt-get--y-install-wget-screen-curl-python-for-debianubuntu">apt-get -y install wget screen curl python #for Debian/Ubuntu</h1>
<p>wget <a href="http://aliyun-oss.linuxeye.com/oneinstack-full.tar.gz">http://aliyun-oss.linuxeye.com/oneinstack-full.tar.gz</a> #阿里云经典网络下载
wget <a href="http://mirrors.linuxeye.com/oneinstack-full.tar.gz">http://mirrors.linuxeye.com/oneinstack-full.tar.gz</a> #包含源码，国内外均可下载
wget <a href="http://mirrors.linuxeye.com/oneinstack.tar.gz">http://mirrors.linuxeye.com/oneinstack.tar.gz</a> #不包含源码，建议仅国外主机下载
tar xzf oneinstack-full.tar.gz
cd oneinstack #如果需要修改目录(安装、数据存储、Nginx日志)，请修改options.conf文件
screen -S oneinstack #如果网路出现中断，可以执行命令<code>screen -R oneinstack</code>重新连接安装窗口
./install.sh #注：请勿sh install.sh或者bash install.sh这样执行</p>
</li>
</ul>
<p><img   class="lazyload" data-src="https://cdn.uu126.cn/201708/install_oneinstack.png" src="https://cdn.jsdelivr.net/gh/moezx/cdn@3.0.2/img/svg/loader/trans.ajax-spinner-preloader.svg" onerror="imgError(this)"  alt="install_oneinstack" title="install_oneinstack" /></p>
<noscript>
  <img src="https://cdn.uu126.cn/201708/install_oneinstack.png" alt="install_oneinstack" title="install_oneinstack" /></p>
</noscript>
<ul>
<li>
<ul>
<li>开始搭建Ghost（过程可参照官网或烧饼博客）</li>
</ul>
</li>
</ul>
<ol>
<li>更新系统并安装必要软件</li>
</ol>
<pre><code>apt-get update
apt-get upgrade
apt-get -t stretch-backports update
apt-get -t stretch-backports upgrade
</code></pre>
<ol>
<li>安装 Node.js 6.x LTS<br>
方法一：</li>
</ol>
<pre><code>curl -sL https://deb.nodesource.com/setup_6.x | bash -
apt-get install nodejs
</code></pre>
<p>方法二：</p>
<pre><code>国外下载地址：
wget https://nodejs.org/download/release/v6.9.5/node-v6.9.5.tar.gz
国内下载地址：
wget https://npm.taobao.org/mirrors/node/v6.9.5/node-v6.9.5.tar.gz
tar zxvf node-v6.9.5.tar.gz
cd node-v6.9.5
./configure
make &amp;&amp; make install 
</code></pre>
<blockquote>
<p>2017-10-22补充，最新版的Ghost已经不支持Node V6.5版本了，所以嘛……得更新233</p>
</blockquote>
<p>推荐使用方法二，成功率高，如果使用方法一没有成功的话，还可以再使用方法二，成功与否，可以使用<br>
<code>node -v</code> ，如果能显示版本就说明Node.js搭建成功了</p>
<ol>
<li>
<p>配置Nginx（因为前面已搭建好Lnmp，所以这里直接配置站点文件即可）<br>
先配置站点文件</p>
<p>vi /usr/local/nginx/conf/vhost/ghost.conf</p>
</li>
</ol>
<p>然后写入以下内容：</p>
<pre><code>server {
listen 80;
listen 443;
server_name 1984n.win;  #记得改成自己的域名
ssl on;
ssl_certificate /usr/local/nginx/conf/1984.crt; #SSL证书路径
ssl_certificate_key /usr/local/nginx/conf/1984.key;  #SSL证书路径
  location / {
      proxy_set_header   X-Real-IP $remote_addr;
      proxy_set_header   Host      $http_host;
      proxy_pass         http://127.0.0.1:2368;
  }
}
</code></pre>
<p>保存好之后，记得重启一下Nginx。</p>
<ol>
<li>添加 ghost 运行用户（按照官方的说明，需要另建一个账户，名称随便，这里以<code>ghost</code>作为用户名来介绍。首先使用<code>adduser</code> 而不是 <code>useradd</code> 命令添加用户，后者只能添加一个简单的无密码无执行权限的用户，前者是后者的加强版命令</li>
</ol>
<pre><code>adduser ghost
</code></pre>
<p>然后系统会提示你输入两次密码，其他的一律回车即可。接着给予 <code>ghost</code> 用户 <code>sudo</code> 权限，这样这货就可以执行好多操作了。</p>
<pre><code>usermod -aG sudo ghost
</code></pre>
<ol>
<li>安装 Ghost-CLI 和 Ghost 1.x<br>
Ghost 从 1.0 开始，已经不需要其他第三方的软件来保持后台运行、更新、安装等操作，因为他们出了个命令行软件 <code>Ghost-CLI</code> 有了这货，我们再也不需要安装 <code>pm2</code> 来保持后台运行，也不需要用 <code>ghost-upgrade</code> 来升级，因为他基本已经全部带了以前的功能。</li>
</ol>
<p>首先我们需要切换到 <code>ghost</code> 这个用户</p>
<pre><code>su - ghost
</code></pre>
<p>输入密码回车,然后直接用 npm 安装 <code>Ghost-CLI</code></p>
<pre><code>sudo npm i -g ghost-cli
</code></pre>
<p>假设你的博客要放在 <code>/var/www/ghost</code> 目录，那么我们就创建一个并赋予权限</p>
<pre><code>sudo mkdir /var/www/ghost
sudo chown ghost:ghost /var/www/ghost
</code></pre>
<p>进入这个目录就可以开始安装 Ghost 了</p>
<pre><code>cd /var/www/ghost
ghost install
</code></pre>
<p>按照提示输入即可，如果要使用 <code>sqlite3</code> 数据库的，可以将 <code>ghost install</code> 改为：</p>
<pre><code>ghost install local --db=sqlite3
</code></pre>
<p>然后修改 <code>/var/www/ghost/config.development.json</code> 文件，修改自己的域名即可，保存好之后，再使用命令： <code>ghost stop &amp;&amp; ghost estart</code> 命令强行关闭再启动（注意不是重启），看是否正确，正确的输出信息是类似这样的:</p>
<pre><code>ghost@sb-blog:/var/www/ghost$ ghost start
✔ Validating config
✔ Starting Ghost
You can access your blog at https://blog.1984n.win/
Ghost uses direct mail by default
To set up an alternative email method read our docs at https://docs.ghost.org/docs/mail-config
</code></pre>
<p>没问题以后，就可以把这个文件改成正式环境的文件了:</p>
<pre><code>mv config.development.json config.production.json
</code></pre>
<p>然后再使用命令： <code>ghost stop &amp;&amp; ghost estart</code> 命令强行关闭再启动。</p>
<h4 id="注意">注意:</h4>
<p>另外千万不要在 root 用户下执行 ghost 相关命令，否则 <code>/var/www/ghost/.ghostpid</code> 这个文件的权限就变成 <code>root</code> 用户的了，导致后续会遇到 <code>Message: 'EACCES: permission denied, open '/var/www/ghost/.ghostpid''</code></p>
<p>一切正常的话，就可以开始折腾Ghost了。</p>
<p>本文中搭建Ghost的部分步骤来自烧饼博客：<a href="https://sb.sb/debian-ubuntu-install-upgrade-ghost/" target="_blank"  rel="nofollow" ><a href="https://sb.sb/debian-ubuntu-install-upgrade-ghost/">https://sb.sb/debian-ubuntu-install-upgrade-ghost/</a></a> ，还有Ghost官网教程：<a href="https://docs.ghost.org/docs/install" target="_blank"  rel="nofollow" ><a href="https://docs.ghost.org/docs/install">https://docs.ghost.org/docs/install</a></a> ，写完看电影咯。</p>
<p>2017-8-19补充：话说现在新版的Ghost编辑器还是蛮好用的，连小工具都有了，这在以前的0.7.4版本可是没有的，这也极大方便像我这种非代码控，点点即可上传图片、链接等等。</p>
<p><img   class="lazyload" data-src="https://cdn.uu126.cn/201708/ghost_blog02.jpg" src="https://cdn.jsdelivr.net/gh/moezx/cdn@3.0.2/img/svg/loader/trans.ajax-spinner-preloader.svg" onerror="imgError(this)"  alt="ghost_blog02" title="ghost_blog02" /></p>
<noscript>
  <img src="https://cdn.uu126.cn/201708/ghost_blog02.jpg" alt="ghost_blog02" title="ghost_blog02" /></p>
</noscript>
    </div>

    <div class="post-copyright">
  <p class="copyright-item">
    <span class="item-title">文章作者</span>
    <span class="item-content">Feng</span>
  </p>
  <p class="copyright-item">
    <span class="item-title">上次更新</span>
    <span class="item-content">
        2017-09-28
        
    </span>
  </p>
  
  
</div>
<div class="post-reward">
  <input type="checkbox" name="reward" id="reward" hidden />
  <label class="reward-button" for="reward">赞赏支持</label>
  <div class="qr-code">
    
    <label class="qr-code-image" for="reward">
        <img class="image" src="https://cdn.uu126.cn/hugo/wechat.png">
        <span>微信打赏</span>
      </label>
    <label class="qr-code-image" for="reward">
        <img class="image" src="https://cdn.uu126.cn/hugo/alipay.png">
        <span>支付宝打赏</span>
      </label>
  </div>
</div><footer class="post-footer">
      <div class="post-tags">
          <a href="/tags/ghost/">Ghost</a>
          </div>
      <nav class="post-nav">
        <a class="prev" href="/2017/374.html">
            <i class="iconfont icon-left"></i>
            <span class="prev-text nav-default">Ghost1.X博客使用记一</span>
            <span class="prev-text nav-mobile">上一篇</span>
          </a>
        <a class="next" href="/2017/371.html">
            <span class="next-text nav-default">信用卡&#34;黑话&#34;</span>
            <span class="next-text nav-mobile">下一篇</span>
            <i class="iconfont icon-right"></i>
          </a>
      </nav>
    </footer>
  </article>
        </div>
        

  
  <div id="vcomments"></div>
  <script src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script>
  <script src='//unpkg.com/valine/dist/Valine.min.js'></script>
  <script type="text/javascript">
    new Valine({
        el: '#vcomments' ,
        appId: '5sMkTX4FLjetFnfbOhaDTCDJ-9Nh9j0Va',
        appKey: '25KXCqIqAN142RQn4fBrsI87',
        notify:  false ,
        verify:  false ,
        avatar:'mm',
        placeholder: '说点什么吧...',
        visitor:  false 
    });
  </script>

  

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
  <a href="https://uu126.gitee.io/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>

<div class="copyright">
  <span class="copyright-year">  
  Hosted by <a href="https://pages.coding.me" style="font-weight: bold">Coding Pages</a> + <a href="https://cloud.tencent.com/redirect.php?redirect=1005&cps_key=4e78216aea817227ff0c96d93a00fd4b" target="_blank" rel="nofollow">腾讯云 + </a><a href="https://console.upyun.com/register/?invite=S1JeTquHL" target="_blank" rel="nofollow"><span class="with-love"><img src="https://cdn.lancn.cn/images/upyun.png" style="width:45px;vertical-align:middle;" alt="又拍云存储"></span></a>
   </span> 
  <div class="busuanzi-footer">
    <a target="_blank"  href="http://www.beian.miit.gov.cn">浙ICP备11026647号-3</a><span class="post-meta-divider"> | </span><a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=33088102001325"><span class="with-love"><img src="https://cdn.uu126.cn/icon-police.png" style="width:14px;"></span> 浙公网安备33088102001325号</a>
  </div>
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 - 
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>
   

  

  <span class="copyright-year">
    &copy; 
    2012 - 
    2020<span class="heart"><i class="iconfont icon-heart"></i></span><span>Feng</span>
  </span>
</div>

    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  <script src="/lib/highlight/highlight.pack.js?v=20171001"></script>
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>



<script type="text/javascript" src="/js/main.min.c12618f9a600c40bd024996677e951e64d3487006775aeb22e200c990006c5c7.js"></script>








</body>
</html>
